<template>
	<view class="container">
		<view class="carousel">
			<swiper indicator-dots circular="true" duration="400">
				<swiper-item class="swiper-item" v-for="(item, index) in product.imglist" :key="index">
					<view class="image-wrapper"><image :src="item.file_url+'?imageView2/2/w/800'" class="loaded" mode="aspectFill"></image></view>
				</swiper-item>
			</swiper>
		</view>

		<view class="introduce-section">
			<text class="title">{{ product.goods_name }}</text>
			<view class="price-box">
				<text class="price-tip">¥</text>
				<text class="price">{{ product.price }}</text>
				<text class="m-price">¥{{ product.origin_price }}</text>
				<!-- <text class="coupon-tip">7折</text> -->
			</view>
			<view class="bot-row">
				<text>销量: {{ product.order_count }}</text>
				<!-- <text>评分: 5.0</text> -->
				<text>接单率: 76%</text>
				<text>平均2分钟接单</text>
			</view>
		</view>

		<!-- 	<view class="c-list">
		 
			<view class="c-row b-b">
				<text class="tit">优惠券</text>
				<text class="con t-r red">领取优惠券</text>
				<text class="yticon icon-you"></text>
			</view>
			<view class="c-row b-b">
				<text class="tit">促销活动</text>
				<view class="con-list">
					<text>新人首单送20元无门槛代金券</text>
					<text>订单满50减10</text>
					<text>订单满100减30</text>
					<text>单笔购买满两件免邮费</text>
				</view>
			</view>
			<view class="c-row b-b">
				<text class="tit">服务</text>
				<view class="bz-list con">
					<text>7天无理由退换货 ·</text>
					<text>假一赔十 ·</text>
				</view>
			</view>
		</view> -->

		<!-- 评价 -->
		<view class="eva-section" v-if="items.length > 0">
			<view class="e-header">
				<text class="tit">评价</text>
				<text>({{ commentCount }})</text>
				<text class="tip">好评率 {{ product.extend.good_reputation_rate }}%</text>
				<text class="yticon icon-you"></text>
			</view>
			<view class="eva-box" :key="index" v-for="(item, index) in items">
				<image class="portrait" :src="item.user.avatarUrl" mode="aspectFill"></image>
				<view class="right">
					<text class="name">{{ item.user.nickname }}</text>
					<view class="name"><uni-rate disabled="true" :value="item.score / 20"></uni-rate></view>
					<text class="con">{{ item.content }}</text>
					<view class="cu-form-group" style="padding: 0;" v-if="item.pics && item.pics.length>0">
						<view class="grid col-4 grid-square flex-sub">
							<view class="bg-img" v-for="(img, index2) in item.pics" :key="index2" @tap="ViewImage(item.pics,img)" >
								<image :src="img+'?imageView2/2/w/200'" mode="aspectFill"></image>
							</view>
						</view>
					</view>

					<view class="bot">
						<text class="attr"></text>
						<text class="time">{{ item.time_tran }}</text>
					</view>
				</view>
			</view>
			<navigator url="/pages/user/comment" v-if="commentCount > 3" class="cu-btn bg-grey ">
				查看全部评价
			</navigator>
		</view>
		

		<view class="detail-desc padding-sm" v-if="content">
			<view class="d-header"><text>图文详情</text></view>
			<rich-text :nodes="content"></rich-text>
			<!-- <text>{{content}}</text> -->
		</view>

		<!-- 底部操作菜单 -->
		<view class="page-bottom">
			<view @click="updateStatus" class="p-b-btn">
				<text v-if="product.status==2" class=" cuIcon-unlock text-blue lg"></text>
				<text v-if="product.status==1" class=" cuIcon-lock text-blue lg"></text>
				<text>{{product.status==1?'己发布':'已下架'}}</text>
			</view>
			
			<view @click="contact" class="p-b-btn">
				<text class="cuIcon-phone text-orange lg"></text>
				<text>联系商家</text>
			</view>
			<!-- <view class="p-b-btn" :class="{active: favorite}" @click="toFavorite">
				<text class="cuIcon-dianhua text-orange"></text>
				<text>收藏</text>
			</view> -->

			<view class="action-btn-group">
				<button type="primary" class=" action-btn no-border  bg-blue" @click="edit">修改</button>
				<!-- <button type="primary" class=" action-btn no-border add-cart-btn">加入购物车</button> -->
			</view>
		</view>
	</view>
</template>

<script>
import beeApp from '../../beeApp.js';
import uniRate from '@/components/uni-rate/uni-rate.vue';
import parseHtml from '../../util/html-parser.js'
export default {
	components: { uniRate },
	data() {
		return {
			product: {
				imglist: []
			},
			content:"",
			items: [],
			commentCount: 0
		};
	},
	onLoad(options) {
		this.id = options.id;
		this.loadData();
		
	},
	methods: {
		getCommentList: function() {
			var _this = this;

			var params = {
				page: 1,
				limit:3,
				user_id: this.product.user_id,
				fields: 'id,content,user,time_tran,score,pics',
				type: 'daoJia'
			};
			if (this.loadding == 1) {
				return false;
			}
			_this.loadding = 1;
			beeApp.api('/sns/comment/get', params, function(res) {
				_this.loadding = 0;
				if (res.code != 200) {
					beeApp.alert(res.msg);
					return;
				}
				_this.commentCount = res.data.recordsFiltered;
				_this.items = res.data.list;
			});
		},
		loadData() {
			var that = this;
			beeApp.api(
				'/mall/goods/find',
				{
					id: this.id
				},
				function(res) {
					if (res.code != 200) {
						beeApp.alert(res.msg);
						return;
					}
					that.product = res.data;
					var content = res.data.content.replace(/\<img/gi, '<img style="max-width:100%;height:auto" ');
					// that.content = content;
					that.content = parseHtml(content);
					that.getCommentList();
				}
			);
		},
		updateStatus() {
			 var that = this;
			beeApp.api(
				'/mall/goods/updateStatus',
				{
					id: this.id
				},
				function(res) {
					if (res.code != 200) {
						beeApp.alert(res.msg);
						return;
					}
					that.loadData();
				}
			);
		},
		edit() {
			uni.navigateTo({
				url: '/pages/product/add?id=' + this.id
			});
		},
		contact(){
			 uni.makePhoneCall({
				phoneNumber: this.product.user.phone
			});
		},
		stopPrevent() {}
	}
};
</script>

<style lang="scss">
page {
	background: $page-color-base;
	padding-bottom: 160upx;
}
.icon-you {
	font-size: $font-base + 2upx;
	color: #888;
}
.carousel {
	height: 622upx;
	position: relative;
	swiper {
		height: 100%;
	}
	.image-wrapper {
		width: 100%;
		height: 622upx;
	}
	.swiper-item {
		display: flex;
		justify-content: center;
		align-content: center;
		height: 750upx;
		overflow: hidden;
		image {
			width: 100%;
			height: 100%;
		}
	}
}

/* 标题简介 */
.introduce-section {
	background: #fff;
	padding: 20upx 30upx;

	.title {
		font-size: 32upx;
		color: $font-color-dark;
		height: 50upx;
		line-height: 50upx;
	}
	.price-box {
		display: flex;
		align-items: baseline;
		height: 64upx;
		padding: 10upx 0;
		font-size: 26upx;
		color: $uni-color-primary;
	}
	.price {
		font-size: $font-lg + 2upx;
	}
	.m-price {
		margin: 0 12upx;
		color: $font-color-light;
		text-decoration: line-through;
	}
	.coupon-tip {
		align-items: center;
		padding: 4upx 10upx;
		background: $uni-color-primary;
		font-size: $font-sm;
		color: #fff;
		border-radius: 6upx;
		line-height: 1;
		transform: translateY(-4upx);
	}
	.bot-row {
		display: flex;
		align-items: center;
		height: 50upx;
		font-size: $font-sm;
		color: $font-color-light;
		text {
			flex: 1;
		}
	}
}

/* 评价 */
.eva-section {
	display: flex;
	flex-direction: column;
	padding: 20upx 30upx;
	background: #fff;
	margin-top: 16upx;
	.e-header {
		display: flex;
		align-items: center;
		height: 70upx;
		font-size: $font-sm + 2upx;
		color: $font-color-light;
		.tit {
			font-size: $font-base + 2upx;
			color: $font-color-dark;
			margin-right: 4upx;
		}
		.tip {
			flex: 1;
			text-align: right;
		}
		.icon-you {
			margin-left: 10upx;
		}
	}
}
.eva-box {
	display: flex;
	padding: 20upx 0;
	.portrait {
		flex-shrink: 0;
		width: 80upx;
		height: 80upx;
		border-radius: 100px;
	}
	.right {
		flex: 1;
		display: flex;
		flex-direction: column;
		font-size: $font-base;
		color: $font-color-base;
		padding-left: 26upx;
		.con {
			font-size: $font-base;
			color: $font-color-dark;
			padding: 20upx 0;
		}
		.bot {
			display: flex;
			justify-content: space-between;
			font-size: $font-sm;
			color: $font-color-light;
		}
	}
}
/*  详情 */
.detail-desc {
	background: #fff;
	margin-top: 16upx;
	.d-header {
		display: flex;
		justify-content: center;
		align-items: center;
		height: 80upx;
		font-size: $font-base + 2upx;
		color: $font-color-dark;
		position: relative;

		text {
			padding: 0 20upx;
			background: #fff;
			position: relative;
			z-index: 1;
		}
		&:after {
			position: absolute;
			left: 50%;
			top: 50%;
			transform: translateX(-50%);
			width: 300upx;
			height: 0;
			content: '';
			border-bottom: 1px solid #ccc;
		}
	}
}

/* 规格选择弹窗 */
.attr-content {
	padding: 10upx 30upx;
	.a-t {
		display: flex;
		image {
			width: 170upx;
			height: 170upx;
			flex-shrink: 0;
			margin-top: -40upx;
			border-radius: 8upx;
		}
		.right {
			display: flex;
			flex-direction: column;
			padding-left: 24upx;
			font-size: $font-sm + 2upx;
			color: $font-color-base;
			line-height: 42upx;
			.price {
				font-size: $font-lg;
				color: $uni-color-primary;
				margin-bottom: 10upx;
			}
			.selected-text {
				margin-right: 10upx;
			}
		}
	}
	.attr-list {
		display: flex;
		flex-direction: column;
		font-size: $font-base + 2upx;
		color: $font-color-base;
		padding-top: 30upx;
		padding-left: 10upx;
	}
	.item-list {
		padding: 20upx 0 0;
		display: flex;
		flex-wrap: wrap;
		text {
			display: flex;
			align-items: center;
			justify-content: center;
			background: #eee;
			margin-right: 20upx;
			margin-bottom: 20upx;
			border-radius: 100upx;
			min-width: 60upx;
			height: 60upx;
			padding: 0 20upx;
			font-size: $font-base;
			color: $font-color-dark;
		}
		.selected {
			background: #fbebee;
			color: $uni-color-primary;
		}
	}
}

/*  弹出层 */
.popup {
	position: fixed;
	left: 0;
	top: 0;
	right: 0;
	bottom: 0;
	z-index: 99;

	&.show {
		display: block;
		.mask {
			animation: showPopup 0.2s linear both;
		}
		.layer {
			animation: showLayer 0.2s linear both;
		}
	}
	&.hide {
		.mask {
			animation: hidePopup 0.2s linear both;
		}
		.layer {
			animation: hideLayer 0.2s linear both;
		}
	}
	&.none {
		display: none;
	}
	.mask {
		position: fixed;
		top: 0;
		width: 100%;
		height: 100%;
		z-index: 1;
		background-color: rgba(0, 0, 0, 0.4);
	}
	.layer {
		position: fixed;
		z-index: 99;
		bottom: 0;
		width: 100%;
		min-height: 40vh;
		border-radius: 10upx 10upx 0 0;
		background-color: #fff;
		.btn {
			height: 66upx;
			line-height: 66upx;
			border-radius: 100upx;
			background: $uni-color-primary;
			font-size: $font-base + 2upx;
			color: #fff;
			margin: 30upx auto 20upx;
		}
	}
	@keyframes showPopup {
		0% {
			opacity: 0;
		}
		100% {
			opacity: 1;
		}
	}
	@keyframes hidePopup {
		0% {
			opacity: 1;
		}
		100% {
			opacity: 0;
		}
	}
	@keyframes showLayer {
		0% {
			transform: translateY(120%);
		}
		100% {
			transform: translateY(0%);
		}
	}
	@keyframes hideLayer {
		0% {
			transform: translateY(0);
		}
		100% {
			transform: translateY(120%);
		}
	}
}
/* 分享 */
.share-section {
	display: flex;
	align-items: center;
	color: $font-color-base;
	background: linear-gradient(left, #fdf5f6, #fbebf6);
	padding: 12upx 30upx;
	.share-icon {
		display: flex;
		align-items: center;
		width: 70upx;
		height: 30upx;
		line-height: 1;
		border: 1px solid $uni-color-primary;
		border-radius: 4upx;
		position: relative;
		overflow: hidden;
		font-size: 22upx;
		color: $uni-color-primary;
		&:after {
			content: '';
			width: 50upx;
			height: 50upx;
			border-radius: 50%;
			left: -20upx;
			top: -12upx;
			position: absolute;
			background: $uni-color-primary;
		}
	}
	.icon-xingxing {
		position: relative;
		z-index: 1;
		font-size: 24upx;
		margin-left: 2upx;
		margin-right: 10upx;
		color: #fff;
		line-height: 1;
	}
	.tit {
		font-size: $font-base;
		margin-left: 10upx;
	}
	.icon-bangzhu1 {
		padding: 10upx;
		font-size: 30upx;
		line-height: 1;
	}
	.share-btn {
		flex: 1;
		text-align: right;
		font-size: $font-sm;
		color: $uni-color-primary;
	}
	.icon-you {
		font-size: $font-sm;
		margin-left: 4upx;
		color: $uni-color-primary;
	}
}

.c-list {
	font-size: $font-sm + 2upx;
	color: $font-color-base;
	background: #fff;
	.c-row {
		display: flex;
		align-items: center;
		padding: 20upx 30upx;
		position: relative;
	}
	.tit {
		width: 140upx;
	}
	.con {
		flex: 1;
		color: $font-color-dark;
		.selected-text {
			margin-right: 10upx;
		}
	}
	.bz-list {
		height: 40upx;
		font-size: $font-sm + 2upx;
		color: $font-color-dark;
		text {
			display: inline-block;
			margin-right: 30upx;
		}
	}
	.con-list {
		flex: 1;
		display: flex;
		flex-direction: column;
		color: $font-color-dark;
		line-height: 40upx;
	}
	.red {
		color: $uni-color-primary;
	}
}

/* 底部操作菜单 */
.page-bottom {
	position: fixed;
	left: 30upx;
	bottom: 30upx;
	z-index: 95;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 690upx;
	height: 100upx;
	background: rgba(255, 255, 255, 0.9);
	box-shadow: 0 0 20upx 0 rgba(0, 0, 0, 0.5);
	border-radius: 16upx;

	.p-b-btn {
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		font-size: $font-sm;
		color: $font-color-base;
		padding: 0px 15upx;
		height: 80upx;
		.lg {
			font-size: 40upx;
			line-height: 48upx;
			color: $font-color-light;
		}
		&.active,
		&.active .yticon {
			color: $uni-color-primary;
		}
		.icon-fenxiang2 {
			font-size: 42upx;
			transform: translateY(-2upx);
		}
		.icon-shoucang {
			font-size: 46upx;
		}
	}
	.action-btn-group {
		display: flex;
		height: 76upx;
		border-radius: 100px;
		overflow: hidden;
		/* 	box-shadow: 0 20upx 40upx -16upx #fa436a;
			box-shadow: 1px 2px 5px rgba(219, 63, 96, 0.4);
			background: linear-gradient(to right, #ffac30,#fa436a,#F56C6C); */
		margin-left: 20upx;
		position: relative;
	
		.action-btn {
			display: flex;
			align-items: center;
			justify-content: center;
			width: 380upx;
			height: 100%;
			font-size: $font-base;
			padding: 0;
			border-radius: 0;
		}
	}
}
</style>
